package com.principle.liskov.improve;

/**
 * @author xuehu
 * @date 2020/12/8 10:06
 * 里氏替换原则 改进
 */

public class Liskov {

    public static void main(String[] args) {
        A a = new A();
        System.out.println("11 - 3 = " + a.func1(11, 3));
        System.out.println("1 - 8 = " + a.func1(1, 8));

        System.out.println("----------------------------------------");

        B b = new B();
        //因为B类不再继承A类，因此调用者，不会再认为func1是求减法
        //调用完成的功能就会很明确
        System.out.println("11 - 3 = " + b.func3(11, 3));  //这里本意是求出11-3
        System.out.println("1 - 8 = " + b.func3(1, 8)); // 1 - 8
        System.out.println("11 + 3 + 9 = " + b.func2(11, 3));
    }
}


//创建一个更加基础的基类
class Base {
    //把更加基础的方法和成员写的Base类中

}

//一个程序引出的问题和思考
//A类
class A extends Base {
    //返回两个数的差
    public int func1(int num1, int num2) {
        return num1 - num2;
    }
}

// B类继承了A类
// 增加了一个新的功能:完成两个数相加,然后和9求和,
class B extends Base {
    //如果B需要使用到A类的方法,使用组合关系
    private A a = new A();


    public int func1(int a, int b) {
        return a + b;
    }

    public int func2(int a, int b) {

        return func1(a, b) + 9;
    }

    //我们仍然想使用A的方法
    public int func3(int a, int b) {
        return this.a.func1(a, b);
    }
}